package com.sisgesbyte.dao.proyeccion;

import java.util.List;

import javax.ejb.Stateless;
import javax.inject.Inject;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;

import com.sisgesbyte.dao.beanDao.FiltrosSQLBean;
import com.sisgesbyte.dao.beanDao.ProyeccionCatClienteDetalleRequest;
import com.sisgesbyte.dao.utilDao.CreaFiltroSqlString;
import com.sisgesbyte.data.entity.comun.GenericEntity;
import com.sisgesbyte.data.entity.proyeccion.ProyeccionCatClienteDetEntity;
import com.sisgesbyte.data.util.AbstractFacade;

@Stateless
public class MantProyeccionCatClienteDetDaoImpl extends AbstractFacade<ProyeccionCatClienteDetEntity> implements
		MantProyeccionCatClienteDetDao {

	@Inject
	private CreaFiltroSqlString creaFiltroSqlString;
	
	@PersistenceContext(unitName = "SigesSiscompPU")
	private EntityManager em;

	@Override
	protected EntityManager getEntityManager() {
		return em;
	}
	
	public MantProyeccionCatClienteDetDaoImpl(){
		super(ProyeccionCatClienteDetEntity.class);
	}
	
	@Override
	public List<ProyeccionCatClienteDetEntity> proyeccionCatClienteDetalle(
			FiltrosSQLBean cadenaFiltros) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT pccd.id, pcc.zona_id,pcc.periodo_id,pcc.categoria_cliente_id,cc.categoria canal,pccd.proyeccion_categoria_cliente_id, pccd.producto_id,p.categoria_producto_id, ");
		jpql.append("cp.nombre categoria_producto,p.marca_id, m.marca,p.cod_prod,p.producto,p.precio_promedio, pccd.codigo_banda, pccd.cantidad_proyectada  ");
		jpql.append("FROM proyeccion.proyeccion_categoria_cliente_detalle pccd  ");
		jpql.append("inner join proyeccion.proyeccion_categoria_cliente pcc on pccd.proyeccion_categoria_cliente_id=pcc.id ");
		jpql.append("inner join administracion.producto p on pccd.producto_id=p.id ");
		jpql.append("inner join administracion.categoria_producto cp on p.categoria_producto_id=cp.id ");
		jpql.append("inner join administracion.marca m on p.marca_id=m.id ");
		jpql.append("inner join administracion.categoria_cliente cc on pcc.categoria_cliente_id =cc.id ");
		// concatenamos el filtro
		if (cadenaFiltros != null) {
			StringBuilder filtro = new StringBuilder();
			filtro.append(creaFiltroSqlString.concatenar(cadenaFiltros));
			jpql.append(filtro.toString());
		}
		Query query = em.createNativeQuery(jpql.toString(), ProyeccionCatClienteDetEntity.class);
		if (cadenaFiltros != null && cadenaFiltros.getListaValores() != null
				&& cadenaFiltros.getListaValores().size() > 0) {
			int num = 0;
			for (Object valor : cadenaFiltros.getListaValores()) {
				query.setParameter(++num, valor);
			}
		}
		List<ProyeccionCatClienteDetEntity> ls = query.getResultList();

		return ls;
	}

	@Override
	public GenericEntity guardarProyeccionCategoriaClienteDet(
			ProyeccionCatClienteDetalleRequest request) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT * from proyeccion.sp_registrar_proyeccion_categoria_cliente_detalle(:in_proyeccion_canal_id, :in_producto_id, :in_cantidad_proyectado, :in_codigo_banda)");
		Query query = em.createNativeQuery(jpql.toString(), GenericEntity.class);
		query.setParameter("in_proyeccion_canal_id", request.getProyeccionCategoriaClienteId());
		query.setParameter("in_producto_id", request.getProductoId());
		query.setParameter("in_cantidad_proyectado", request.getCantidadProyectada());
		query.setParameter("in_codigo_banda", request.getCodigo_banda());
		return (GenericEntity) query.getSingleResult();
	}

	@Override
	public GenericEntity actualizarProyeccionCategoriaClienteDet(
			ProyeccionCatClienteDetalleRequest request) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT * from proyeccion.sp_actualizar_proyeccion_categoria_cliente_detalle(:in_id, :in_proyeccion_canal_id, :in_producto_id, :in_cantidad_proyectado, :in_codigo_banda)");
		Query query = em.createNativeQuery(jpql.toString(), GenericEntity.class);
		query.setParameter("in_id", request.getId());
		query.setParameter("in_proyeccion_canal_id", request.getProyeccionCategoriaClienteId());
		query.setParameter("in_producto_id", request.getProductoId());
		query.setParameter("in_cantidad_proyectado", request.getCantidadProyectada());
		query.setParameter("in_codigo_banda", request.getCodigo_banda());
		return (GenericEntity) query.getSingleResult();
	}

	@Override
	public GenericEntity eliminarProyeccionCategoriaClienteDet(int codProyeccion) {
		StringBuilder jpql = new StringBuilder();
		jpql.append("SELECT * from proyeccion.sp_eliminar_proyeccion_categoria_cliente_detalle(:in_id)");
		Query query = em.createNativeQuery(jpql.toString(), GenericEntity.class);
		query.setParameter("in_id", codProyeccion);
		return (GenericEntity) query.getSingleResult();
	}

}
